package com.zjw.algorithm;


/***
 * 给定一个排序数组和一个目标值，在数组中找到目标值，并返回其索引。如果目标值不存在于数组中，返回它将会被按顺序插入的位置。
 *
 * 请必须使用时间复杂度为 O(log n) 的算法。
 *
 *  
 *
 * 示例 1:
 *
 * 输入: nums = [1,3,5,6], target = 5
 * 输出: 2
 * 示例 2:
 *
 * 输入: nums = [1,3,5,6], target = 2
 * 输出: 1
 * 示例 3:
 *
 * 输入: nums = [1,3,5,6], target = 7
 * 输出: 4
 *  
 *
 * 来源：力扣（LeetCode）
 * 链接：https://leetcode.cn/problems/search-insert-position
 * 著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。
 *
 * */
public class Solution3_2 {

    public static void main(String[] args) {
        System.out.println(new Solution3_2().searchInsert(new int[]{1, 3, 5, 6}, 5));
        System.out.println(new Solution3_2().searchInsert(new int[]{1, 3, 5, 6}, 2));
        System.out.println(new Solution3_2().searchInsert(new int[]{1, 3, 5, 6}, 7));
    }

    public int searchInsert(int[] nums, int target) {
        int pl = 0;
        int pr = nums.length - 1;
        int middle = 0;

        while (pl < pr) {
            middle = (pl + pr) >> 1;
            if (nums[middle] == target) {
                return middle;
            }

            if (nums[middle] > target) {
                pr = middle - 1;
            } else {
                pl = middle + 1;
            }
        }

        return nums[pl] >= target ? pl : pl + 1;
    }


}
